

# **Lab 5: 2D Image Convolution**

In this Lab, we are going to using Vivado High Level Synthesis (HLS) tool to create a hardware accelerator for 2D image convolution. You will need both this document and the lecture recording to be able get this lab done.

#### 1. Vivado HLS

This section will walk you through creating a new Vivado HLS project

- a. Download the lab5 template.zip and extract it.
- b. Open Vivado HLS and click on New Project.



c. Choose a project name and make sure that the path to it doesn't have any spaces at all! Click Next.





- d. Copy the folder name "vhls" under lab5\_template folder and paste in the folder of the project.
- e. Choose the following files as your sources:



f. Next to Top Function, click on browse and choose hw\_conv (convolution.cpp) as the top function. Click Next.

Note: this image is just missing the rock512.pgm file, but it should be there.



g. Choose the testbench.cpp as your simulation file. Click Next.





h. In this window, we are going to choose ZYNQ Part number: search for: xc7z020clg and choose the following part number: Click Ok.



i. Click Finish here





between Synthesis Switch View This is what the project should look like now. Simulation (Debug)



#### 2. Synthesizing Top Function

Now you should open the convolution.cpp and start implementing the function names hw conv and sw conv. Note that you would only need the hw conv to be completed before running the synthesize step. In this step, Vivado HLS will try and generate hardware (.vhd) file representing this Top Function. It will take into consideration all the directive written and will try to optimize your design as it can. Note that different C code for this part will yield to different implementation and VERY different resources utilization, so make sure to optimize your C code as much as you can.

- When you are done implementing your C function, click on the Synthesize button.
- b. If there were no errors in the synthesis and implementation, you should see the following window. Any errors will be displayed in the console window, you can go back and fix them.



c. This is the generated Synthesis Report, which has an estimate of the Performance (Timing, maximum Clock frequency, Utilization, no. of each of the resources used, and the Interface ports).

Familiarize yourself with this report, expand different parts and read it. You will be needing to report the Timing and Utilization Estimates for your design. Again, different designs will have very different utilization summary.

d. Now you are ready to Simulate. Click on the Run Simulation Icon, and Check Launch Debug in the following window.

Note: you might also want to check Clean Build in between runs, just to make sure that nothing gets written over.





e. If the simulation was able to start successfully, then you the view will be switched to the Debug view as in the following window. This is the Debug mode, so you are able to go through your code step by step. If you wish to run your code entirely, Click on Resume (the first icon to the left) or hit F8. In the following Simulation runs, if you don't wish to go in the Debug mode and run the code directly, uncheck the "Launch Debugger" in the previous step.



f. Any errors, will appear in the console window, you can go back and fix them. If the code was run in its entirety with no errors, you will see the following window. Note that the exit code is zero, meaning no issues.





g. This code will generate 2 images, one from the sw\_conv (output\_sw.pgm) and one form the hw\_conv (output\_hw.pgm). You can view these files by navigating to: "project dir"/"solution name"/csim/build.

Note that solution name in my case is solution1. rock512.pgm is the original picture.

In order to view those pictures, you would need to download the following image viewer from this link: <a href="https://www.irfanview.com/">https://www.irfanview.com/</a>

You will find that output\_sw.pgm is a blurred version of the original picture. If your code for hw conv is correct, both output hw.pgm and output sw.pgm should be exactly the same.



#### 3. Generating and IP for your hw conv function

After the whole process, you will see VHDL files generated by the HLS under solution1->impl->vhdl in the Explorer window. Please open these VHDL files and take a look. You might have different number of files depending on your implementation.

```
| Compared Section | Compared Se
```



a. Click "Export RTL" button as labeled below to export RTL as IP.

b. We will use VHDL as RTL. You can change the name of the IP by editing "Configuration" and editing the "Display Name" property. Click "OK", and then it will generate the IP into the "impl" folder. Now, you have the conv\_hw accelerator successfully designed.









#### 4. Final Bitstream Generation using Vivado

With generated IP, now we are ready to combine the accelerator with existing library modules such as DMA and ZYNQ together to implement the architecture to implement the architecture and deploy it on the board. In the provided "lab5\_template" folder, a folder named "vivado" has a template Vivado project that has all the peripherals and components needed to generate the bitstream, except for the conv\_hw generated IP. You will be using this project to include the ip you just generated and generate the bitstream.

- a. Copy the provided folder named "vivado" into the project directory you created for lab 5.
- b. Open the project file under "vivado/lab5". Open system.bd diagram. Expand the Accel hierarchy. This is what it looks like. The AXIS\_DATA\_FIFO is just a first in first out accelerator that we are going to replace without generated conv hw function.





- c. We need to add the ip repo of the generated conv\_hw. Add the following folder "your project directory\"solution name"\impl\ip" to your ip repositors directories.
- d. Delete the AXIS\_DATA\_FIFO and replace it with the conv\_hw component. The project should look like this. Note the icon in the middle of the component which indicates that it's an HLS generated component.





e. Now, generate the HDL wrapper and the bitstream. If everything went well, you should be able to successfully generate the bitstream.

## What to do:

This section will be updated over time, so please make sure to always refer to the latest version. I will also make an announcement for each update. For now:

- 1. You should design the conv\_hw and conv\_sw functions in the provided convolution.cpp template. You will be needing to watch the lecture recording along with this document in order to get the job done.
- 2. Synthesize the Top Function and generate the Synthesis Report. You will be writing a report for this Lab so make sure to get screenshots that would report the all parts of the report.
- 3. Simulate the c testbench and have a look at the generated picture, your hw and sw generated pic should be matching. Those pictures will be included in the report as well.
- 4. Generate the ip for conv\_hw and use the provided vivado template to generate the bitstream. A screenshot confirming that you have successfully generated the bit stream would be included in the report.
- 5. If you attempted the Bonus part, please add a section in this report, following step 10 description in the bonus part.

# **Deliverables:**

- 1. You will be delivering all the VHDL and C codes that you have written, including the design files, testbenches, and the C codes. The submission will be on Canvas Assignment for Lab 4. You can just Zip the top Vivado project folder that has all the files that was mentioned above. (please make sure that it has all the files required).
- 2. Check-offs will be done on the due date for this assignment. The rubric for the check-offs will be provided later.

# **Bonus (3%):**

## Running the accelerator on your FPGA board

For this part, you are going to use the sd card that comes with the kit, the usb cable, Putty, and the generated bitstream from Vivado.

- 1. Use an sd card reader and the sd card that comes with you kit to format it. From Windows, right click on the sd card then click format, then start.
- 2. Copy the following two files "BOOT.BIN" and "image.ub" from the sd card folder provided under lab5 template, then past them directly under your sd card.
- 3. Navigate to your lab 5 Vivado working folder and copy the file called "system\_wrapper.bit". This is the generated bitstream. Paste this file also directly under your sd card. Follow the path in the following picture:





4. When you are done with these 3 steps, your final sd card directory should look like that:



5. Insert the sd card in the sd card slot in the board and switch J14 to SD.





6. Connect the board through USB cable, turn the board on, then wait till LD12 (Done) led turns green. Now start Putty. Note, you might a bunch of commands being executed on Putty, this is fine. Just wait till you see the following line. If you started Putty a while after the led turns green, then you might just see a blank screen.

```
🚰 COM11 - PuTTY
haveged: haveged: cpu: (VC); data: 16K (D); inst: 16K (D); idx: 12/40; sz: 15012
/57848
haveged: haveged: tot tests(BA8): A:1/1 B:1/1 continuous tests(B): last entropy
estimate 7.99899
haveged: haveged: fills: 0, generated: 0
random: crng init done
Public key portion is:
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCz7aNxwWntJdQoACno9VowTEFszjepR1ydloUvHFge
NehxCPpkXFIvOJFAIBaXO1F14DYKUTPYbaROtaEwuAAsAX/VX3r9Rls8cyqgalIKEqA4QknPrGMQiiu1
7LAnHbBTNmTP6YYDTiDrcQWPXiKy1zhWd1pe1EEXPgu5N+YLCkFzY9EbNQ0h9xHQv/yXoxoq8t1CXqCS
9/YTHYW698qDuTmtCagS08YYdD7xW221QtkXdK5UYEspZk86Pd8McYnk6mwzVNF87j5ETa6XkFyCo0r3
cECsoQYBbqyZ2WhKfs0a0yEvnRfySJLZ9aaCgrfANql6QaSfbmGXKtLhdG0B root@zynqpeta
Fingerprint: shal!! 10:ec:05:98:62:a2:0e:91:a9:0b:ea:98:f5:b7:a3:87:99:46:4d:cc
hwclock: can't open '/dev/misc/rtc': No such file or directory
Starting internet superserver: inetd.
Starting syslogd/klogd: done
Starting tcf-agent: OK
Last login: Sat Oct 24 03:22:37 UTC 2020 on tty1
root@zynqpeta:~#
```

7. We are going to execute the following commands, one at a time, to instantiate the accelerator and save the image to the sd card. Any line that is in red is just a comment for you.

```
exit #DNE

# run CONV accelerator (input: rock512.pgm (512x512 Y), output: output_accel.pgm
(512x512 Y))
axidma 1 /dev/axidma0 ./rock512.pgm ./output_accel.pgm 512 512 1

# sample output (when you run the above command, the execution time will be reported, take a note of that as you will be reporting it later on)
# time: 0.002669

# now we need to mount the sd card, copy the output picture to it to view it on the PC
mount /dev/mmcblk0p1 /mnt
cp output_accel.pgm /mnt/output_accel.pgm
sync
umount /mnt
```

8. Take a screenshot of your Putty Window. You can now turn off the board, extract the sd card and plug it back to your PC reader.



9. If everything went well, you should find the convoluted picture in the contents of your SD card.



- 10. Add a section in your report for the bonus part. You should be reporting the following:
  - a. A screenshot showing the communication done over Putty and you executing these commands.
  - b. Report the time your accelerator took to execute.
  - c. Include the conv pic from your accelerator, and the one generated form the HW simulation. Add them next to each other, they should be identical.
  - d. If anything went wrong, reflect on that and say what you think went wrong and how you might fix it.